HEX
Server: LiteSpeed
System: Linux php-prod-1.spaceapp.ru 5.15.0-160-generic #170-Ubuntu SMP Wed Oct 1 10:06:56 UTC 2025 x86_64
User: xnsbb3110 (1041)
PHP: 8.1.33
Disabled: NONE
Upload Files
File: /home/shaping-sar.ru/public_html/wp-content/themes/beauty spa/includes/sample-config.php
<?php
/**
 * ReduxFramework Sample Config File
 * For full documentation, please visit: http://docs.reduxframework.com/
 */
if (! class_exists ( 'Redux_Framework_sample_config' )) {
	class Redux_Framework_sample_config {
		public $args = array ();
		public $sections = array ();
		public $theme;
		public $ReduxFramework;
		public function __construct() {
			if (! class_exists ( 'ReduxFramework' )) {
				return;
			}

			// This is needed. Bah WordPress bugs. ;)
			if (true == Redux_Helpers::isTheme ( __FILE__ )) {
				$this->initSettings ();
			} else {
				add_action ( 'plugins_loaded', array (
						$this,
						'initSettings'
				), 10 );
			}
		}
		public function initSettings() {

			// Just for demo purposes. Not needed per say.
			$this->theme = wp_get_theme ();

			// Set the default arguments
			$this->setArguments ();

			// Set a few help tabs so you can see how it's done
			$this->setHelpTabs ();

			// Create the sections and fields
			$this->setSections ();

			if (! isset ( $this->args ['opt_name'] )) { // No errors please
				return;
			}

			// If Redux is running as a plugin, this will remove the demo notice and links
			add_action ( 'redux/loaded', array (
					$this,
					'remove_demo'
			) );

			// Function to test the compiler hook and demo CSS output.
			// Above 10 is a priority, but 2 in necessary to include the dynamically generated CSS to be sent to the function.
			// add_filter('redux/options/'.$this->args['opt_name'].'/compiler', array( $this, 'compiler_action' ), 10, 3);

			// Change the arguments after they've been declared, but before the panel is created
			// add_filter('redux/options/'.$this->args['opt_name'].'/args', array( $this, 'change_arguments' ) );

			// Change the default value of a field after it's been set, but before it's been useds
			// add_filter('redux/options/'.$this->args['opt_name'].'/defaults', array( $this,'change_defaults' ) );

			// Dynamically add a section. Can be also used to modify sections/fields
			// add_filter('redux/options/' . $this->args['opt_name'] . '/sections', array($this, 'dynamic_section'));

			$this->ReduxFramework = new ReduxFramework ( $this->sections, $this->args );
		}

		/**
		 * This is a test function that will let you see when the compiler hook occurs.
		 * It only runs if a field set with compiler=>true is changed.
		 */
		function compiler_action($options, $css, $changed_values) {
			echo '<h1>The compiler hook has run!</h1>';
			echo "<pre>";
			print_r ( $changed_values ); // Values that have changed since the last save
			echo "</pre>";
			// print_r($options); //Option values
			// print_r($css); // Compiler selector CSS values compiler => array( CSS SELECTORS )

			/*
			 * // Demo of how to use the dynamic CSS and write your own static CSS file
			 * $filename = dirname(__FILE__) . '/style' . '.css';
			 * global $wp_filesystem;
			 * if( empty( $wp_filesystem ) ) {
			 * require_once( ABSPATH .'/wp-admin/includes/file.php' );
			 * WP_Filesystem();
			 * }
			 *
			 * if( $wp_filesystem ) {
			 * $wp_filesystem->put_contents(
			 * $filename,
			 * $css,
			 * FS_CHMOD_FILE // predefined mode settings for WP files
			 * );
			 * }
			 */
		}

		/**
		 * Custom function for filtering the sections array.
		 * Good for child themes to override or add to the sections.
		 * Simply include this function in the child themes functions.php file.
		 * NOTE: the defined constants for URLs, and directories will NOT be available at this point in a child theme,
		 * so you must use get_template_directory_uri() if you want to use any of the built in icons
		 */
		function dynamic_section($sections) {
			// $sections = array();
			$sections [] = array (
					'title' => __ ( 'Section via hook', 'redux-framework-demo' ),
					'desc' => __ ( '<p class="description">This is a section created by adding a filter to the sections array. Can be used by child themes to add/remove sections from the options.</p>', 'redux-framework-demo' ),
					'icon' => 'el-icon-paper-clip',
					// Leave this as a blank section, no options just some intro text set above.
					'fields' => array ()
			);

			return $sections;
		}

		/**
		 * Filter hook for filtering the args.
		 * Good for child themes to override or add to the args array. Can also be used in other functions.
		 */
		function change_arguments($args) {
			// $args['dev_mode'] = true;
			return $args;
		}

		/**
		 * Filter hook for filtering the default value of any given field.
		 * Very useful in development mode.
		 */
		function change_defaults($defaults) {
			$defaults ['str_replace'] = 'Testing filter hook!';

			return $defaults;
		}

		// Remove the demo link and the notice of integrated demo from the redux-framework plugin
		function remove_demo() {

			// Used to hide the demo mode link from the plugin page. Only used when Redux is a plugin.
			if (class_exists ( 'ReduxFrameworkPlugin' )) {
				remove_filter ( 'plugin_row_meta', array (
						ReduxFrameworkPlugin::instance (),
						'plugin_metalinks'
				), null, 2 );

				// Used to hide the activation notice informing users of the demo panel. Only used when Redux is a plugin.
				remove_action ( 'admin_notices', array (
						ReduxFrameworkPlugin::instance (),
						'admin_notices'
				) );
			}
		}
		public function setSections() {

			/**
			 * Used within different fields.
			 * Simply examples. Search for ACTUAL DECLARATION for field examples
			 */
			// Background Patterns Reader
			$sample_patterns_path = ReduxFramework::$_dir . '../sample/patterns/';
			$sample_patterns_url = ReduxFramework::$_url . '../sample/patterns/';
			$sample_patterns = array ();

			if (is_dir ( $sample_patterns_path )) :

				if ($sample_patterns_dir = opendir ( $sample_patterns_path )) :
					$sample_patterns = array ();

					while ( ($sample_patterns_file = readdir ( $sample_patterns_dir )) !== false ) {

						if (stristr ( $sample_patterns_file, '.png' ) !== false || stristr ( $sample_patterns_file, '.jpg' ) !== false) {
							$name = explode ( '.', $sample_patterns_file );
							$name = str_replace ( '.' . end ( $name ), '', $sample_patterns_file );
							$sample_patterns [] = array (
									'alt' => $name,
									'img' => $sample_patterns_url . $sample_patterns_file
							);
						}
					}






                    endif;






                endif;

			ob_start ();

			$ct = wp_get_theme ();
			$this->theme = $ct;
			$item_name = $this->theme->get ( 'Name' );
			$tags = $this->theme->Tags;
			$screenshot = $this->theme->get_screenshot ();
			$class = $screenshot ? 'has-screenshot' : '';

			$customize_title = sprintf ( __ ( 'Customize &#8220;%s&#8221;', 'redux-framework-demo' ), $this->theme->display ( 'Name' ) );

			?>
<div id="current-theme" class="<?php echo esc_attr( $class ); ?>">
                    <?php if ( $screenshot ) : ?>
                        <?php if ( current_user_can( 'edit_theme_options' ) ) : ?>
                            <a href="<?php echo wp_customize_url(); ?>"
		class="load-customize hide-if-no-customize"
		title="<?php echo esc_attr( $customize_title ); ?>"> <img
		src="<?php echo esc_url( $screenshot ); ?>"
		alt="<?php esc_attr_e( 'Current theme preview', 'redux-framework-demo' ); ?>" />
	</a>
                        <?php endif; ?>
                        <img class="hide-if-customize"
		src="<?php echo esc_url( $screenshot ); ?>"
		alt="<?php esc_attr_e( 'Current theme preview', 'redux-framework-demo' ); ?>" />
                    <?php endif; ?>

                    <h4><?php echo $this->theme->display( 'Name' ); ?></h4>

	<div>
		<ul class="theme-info">
			<li><?php printf( __( 'By %s', 'redux-framework-demo' ), $this->theme->display( 'Author' ) ); ?></li>
			<li><?php printf( __( 'Version %s', 'redux-framework-demo' ), $this->theme->display( 'Version' ) ); ?></li>
			<li><?php echo '<strong>' . __( 'Tags', 'redux-framework-demo' ) . ':</strong> '; ?><?php printf( $this->theme->display( 'Tags' ) ); ?></li>
		</ul>
		<p class="theme-description"><?php echo $this->theme->display( 'Description' ); ?></p>
                        <?php
			if ($this->theme->parent ()) {
				printf ( ' <p class="howto">' . __ ( 'This <a href="%1$s">child theme</a> requires its parent theme, %2$s.', 'redux-framework-demo' ) . '</p>', __ ( 'http://codex.wordpress.org/Child_Themes', 'redux-framework-demo' ), $this->theme->parent ()->display ( 'Name' ) );
			}
			?>

                    </div>
</div>

<?php
			$item_info = ob_get_contents ();

			ob_end_clean ();

			$sampleHTML = '';
			if (file_exists ( dirname ( __FILE__ ) . '/info-html.html' )) {
				Redux_Functions::initWpFilesystem ();

				global $wp_filesystem;

				$sampleHTML = $wp_filesystem->get_contents ( dirname ( __FILE__ ) . '/info-html.html' );
			}

			// ACTUAL DECLARATION OF SECTIONS
			$this->sections [] = array (
					'title' => __ ( 'Settings', 'redux-framework-demo' ),
					'desc' => __ ( 'Redux Framework was created with the developer in mind. It allows for any theme developer to have an advanced theme panel with most of the features a developer would need. For more information check out the Github repo at: <a href="https://github.com/ReduxFramework/Redux-Framework">https://github.com/ReduxFramework/Redux-Framework</a>', 'redux-framework-demo' ),
					'icon' => 'el-icon-home',
					// 'submenu' => false, // Setting submenu to false on a given section will hide it from the WordPress sidebar menu!
					'fields' => array (

							array (
									'id' => 'logo',
									'type' => 'media',
									'title' => __ ( 'Logo', 'redux-framework-demo' ),
									'compiler' => 'true',
									'mode' => false,
									// Can be set to false to allow any media type, or can also be set to any mime type.
									'desc' => __ ( 'Upload Logo.', 'redux-framework-demo' ),
									'subtitle' => __ ( 'Upload any media using the WordPress native uploader', 'redux-framework-demo' ),
									'hint' => array (
											// 'title' => '',
											'content' => 'This is for<b>logo</b> Dark for highlighting in white background.'
									)
							),

							array (
									'id' => 'favicon',
									'type' => 'media',
									'title' => __ ( 'Favicon', 'redux-framework-demo' ),
									'compiler' => 'true',
									'mode' => false,
									// Can be set to false to allow any media type, or can also be set to any mime type.
									'desc' => __ ( 'Upload Favicon Image.', 'redux-framework-demo' ),
									'subtitle' => __ ( 'Upload any media using the WordPress native uploader', 'redux-framework-demo' ),
									'hint' => array (
											// 'title' => '',
											'content' => 'This is a <b>hint</b> tool-tip for the favicon upload field.'
									)
							),
							array (
									'id' => 'loader',
									'type' => 'switch',
									'title' => __ ( 'Loader Hide', 'redux-framework-demo' ),
									'subtitle' => __ ( 'Loader Hide Enable', 'redux-framework-demo' ),
									'desc' => __ ( 'Enable to hide loader', 'redux-framework-demo' ),
									'default' => 0,
									'off' => 'Disabled',
									'on' => 'Enabled'
							),

							array (
									'id' => 'copyright',
									'type' => 'editor',
									'wpautop' => true,
									'compiler' => 'true',
									'title' => __ ( 'Copyright text of the WebSite', 'bautySpa' ),
									'subtitle' => __ ( 'Write a Copyright text of your WebSite', 'bautySpa' ),
									'default' => 'Powered by bautySpa.',
									'args' => array (
											'teeny' => true,
											'textarea_rows' => 10
									)
							),
							array (
									'id' => 'style_switcher',
									'type' => 'select',
									'title' => __ ( 'Select Css File', 'bautySpa' ),
									'subtitle' => __ ( 'Select Your Website Css File.', 'bautySpa' ),
									'options' => array (
											'style1' => __ ( 'Light 1', 'bautySpa' ),
											'color-2' => __ ( 'Light 2', 'bautySpa' ),
											'color-3' => __ ( 'Light 3', 'bautySpa' ),
											'color-4' => __ ( 'Light 4', 'bautySpa' ),
											'color-5' => __ ( 'Light 5', 'bautySpa' ),
											'dark-1' => __ ( 'Dark 1', 'bautySpa' ),
											'dark-2' => __ ( 'Dark 2', 'bautySpa' ),
											'dark-3' => __ ( 'Dark 3', 'bautySpa' ),
											'dark-4' => __ ( 'Dark 4', 'bautySpa' ),
											'dark-5' => __ ( 'Dark 5', 'bautySpa' ),
									),
									'default' => 'style1'
							),
							array (
									'id' => 'theme_switcher',
									'type' => 'select',
									'title' => __ ( 'Select Theme', 'bautySpa' ),
									'subtitle' => __ ( 'Select Your Desire Theme.', 'bautySpa' ),
									'options' => array (
											'default' => __ ( 'Normal Version', 'bautySpa' ),
											'para' => __ ( 'Paralax Version', 'bautySpa' ),
									),
									'default' => 'default'
							),

							/**
							 * ** ========= BLOGS DETAILS========********
							 */
							array (
									'id' => 'blog-page-details-head',
									'type' => 'textarea',
									'title' => __ ( 'Blog Detail Page Heading', 'redux-framework-demo' ),
									'subtitle' => __ ( 'Specify the Blog Detail Page Heading.', 'redux-framework-demo' ),
									'default' => 'BLOG DETAILS'
							),
							array (
									'id' => 'blog-details-head-para',
									'type' => 'media',
									'title' => __ ( 'Blog Detail Page Paralax', 'redux-framework-demo' ),
									'compiler' => 'true',
									'mode' => false,
									// Can be set to false to allow any media type, or can also be set to any mime type.
									'desc' => __ ( 'Blog Detail Page Paralax Image.', 'redux-framework-demo' ),
									'subtitle' => __ ( 'Upload any media using the WordPress native uploader', 'redux-framework-demo' ),
									'hint' => array (
											// 'title' => '',
											'content' => 'This is a <b>hint</b> tool-tip for the Blog Detail Page Paralax Image.'
									)
							)
					)
			);
			$this->sections[] = array(
                'icon'      => 'el-icon-check',
                'title'     => __('RTL', 'redux-framework-demo'),
                'desc'      => __('<p class="description">You can change your site from right to left.</p>', 'redux-framework-demo'),
                'fields'    => array(

                    array(
                        'id'        => 'rtl_css',
                        'type'      => 'switch',
                        'title'     => __('Enable RTL Mode', 'redux-framework-demo'),
                        'subtitle'  => __('Display Site From Right to Left', 'redux-framework-demo'),
                        'default'   => '0',
                    ),


                )
            );

			$this->sections [] = array (
					'type' => 'divide'
			);

			$theme_info = '<div class="redux-framework-section-desc">';
			$theme_info .= '<p class="redux-framework-theme-data description theme-uri">' . __ ( '<strong>Theme URL:</strong> ', 'redux-framework-demo' ) . '<a href="' . $this->theme->get ( 'ThemeURI' ) . '" target="_blank">' . $this->theme->get ( 'ThemeURI' ) . '</a></p>';
			$theme_info .= '<p class="redux-framework-theme-data description theme-author">' . __ ( '<strong>Author:</strong> ', 'redux-framework-demo' ) . $this->theme->get ( 'Author' ) . '</p>';
			$theme_info .= '<p class="redux-framework-theme-data description theme-version">' . __ ( '<strong>Version:</strong> ', 'redux-framework-demo' ) . $this->theme->get ( 'Version' ) . '</p>';
			$theme_info .= '<p class="redux-framework-theme-data description theme-description">' . $this->theme->get ( 'Description' ) . '</p>';
			$tabs = $this->theme->get ( 'Tags' );
			if (! empty ( $tabs )) {
				$theme_info .= '<p class="redux-framework-theme-data description theme-tags">' . __ ( '<strong>Tags:</strong> ', 'redux-framework-demo' ) . implode ( ', ', $tabs ) . '</p>';
			}
			$theme_info .= '</div>';

			$this->sections [] = array (
					'title' => __ ( 'Import / Export', 'redux-framework-demo' ),
					'desc' => __ ( 'Import and Export your Redux Framework settings from file, text or URL.', 'redux-framework-demo' ),
					'icon' => 'el-icon-refresh',
					'fields' => array (
							array (
									'id' => 'opt-import-export',
									'type' => 'import_export',
									'title' => 'Import Export',
									'subtitle' => 'Save and restore your Redux options',
									'full_width' => false
							)
					)
			);

			$this->sections [] = array (
					'type' => 'divide'
			);

			$this->sections [] = array (
					'icon' => 'el-icon-info-sign',
					'title' => __ ( 'Theme Information', 'redux-framework-demo' ),
					'desc' => __ ( '<p class="description">This is the Description. Again HTML is allowed</p>', 'redux-framework-demo' ),
					'fields' => array (
							array (
									'id' => 'opt-raw-info',
									'type' => 'raw',
									'content' => $item_info
							)
					)
			);
		}
		public function setHelpTabs() {

			// Custom page help tabs, displayed using the help API. Tabs are shown in order of definition.
			$this->args ['help_tabs'] [] = array (
					'id' => 'redux-help-tab-1',
					'title' => __ ( 'Theme Information 1', 'redux-framework-demo' ),
					'content' => __ ( '<p>This is the tab content, HTML is allowed.</p>', 'redux-framework-demo' )
			);

			$this->args ['help_tabs'] [] = array (
					'id' => 'redux-help-tab-2',
					'title' => __ ( 'Theme Information 2', 'redux-framework-demo' ),
					'content' => __ ( '<p>This is the tab content, HTML is allowed.</p>', 'redux-framework-demo' )
			);

			// Set the help sidebar
			$this->args ['help_sidebar'] = __ ( '<p>This is the sidebar content, HTML is allowed.</p>', 'redux-framework-demo' );
		}

		/**
		 * All the possible arguments for Redux.
		 * For full documentation on arguments, please refer to: https://github.com/ReduxFramework/ReduxFramework/wiki/Arguments
		 */
		public function setArguments() {
			$theme = wp_get_theme (); // For use with some settings. Not necessary.

			$this->args = array (
					// TYPICAL -> Change these values as you need/desire
					'opt_name' => 'beauty_demo',
					// This is where your data is stored in the database and also becomes your global variable name.
					'display_name' => $theme->get ( 'Name' ),
					// Name that appears at the top of your panel
					'display_version' => $theme->get ( 'Version' ),
					// Version that appears at the top of your panel
					'menu_type' => 'menu',
					// Specify if the admin menu should appear or not. Options: menu or submenu (Under appearance only)
					'allow_sub_menu' => true,
					// Show the sections below the admin menu item or not
					'menu_title' => __ ( 'Beauty Spa Theme Options', 'redux-framework-demo' ),
					'page_title' => __ ( 'Beauty Spa Options', 'redux-framework-demo' ),
					// You will need to generate a Google API key to use this feature.
					// Please visit: https://developers.google.com/fonts/docs/developer_api#Auth
					'google_api_key' => '',
					// Set it you want google fonts to update weekly. A google_api_key value is required.
					'google_update_weekly' => false,
					// Must be defined to add google fonts to the typography module
					'async_typography' => true,
					// Use a asynchronous font on the front end or font string
					// 'disable_google_fonts_link' => true, // Disable this in case you want to create your own google fonts loader
					'admin_bar' => true,
					// Show the panel pages on the admin bar
					'admin_bar_icon' => 'dashicons-portfolio',
					// Choose an icon for the admin bar menu
					'admin_bar_priority' => 50,
					// Choose an priority for the admin bar menu
					'global_variable' => '',
					// Set a different name for your global variable other than the opt_name
					'dev_mode' => false,
					// Show the time the page took to load, etc
					'update_notice' => true,
					// If dev_mode is enabled, will notify developer of updated versions available in the GitHub Repo
					'customizer' => true,
					// Enable basic customizer support
					// 'open_expanded' => true, // Allow you to start the panel in an expanded way initially.
					// 'disable_save_warn' => true, // Disable the save warning when a user changes a field

					// OPTIONAL -> Give you extra features
					'page_priority' => null,
					// Order where the menu appears in the admin area. If there is any conflict, something will not show. Warning.
					'page_parent' => 'themes.php',
					// For a full list of options, visit: http://codex.wordpress.org/Function_Reference/add_submenu_page#Parameters
					'page_permissions' => 'manage_options',
					// Permissions needed to access the options panel.
					'menu_icon' => '',
					// Specify a custom URL to an icon
					'last_Forctab' => '',
					// e your panel to always open to a specific tab (by id)
					'page_icon' => 'icon-themes',
					// Icon displayed in the admin panel next to your menu_title
					'page_slug' => '_options',
					// Page slug used to denote the panel
					'save_defaults' => true,
					// On load save the defaults to DB before user clicks save or not
					'default_show' => false,
					// If true, shows the default value next to each field that is not the default value.
					'default_mark' => '',
					// What to print by the field's title if the value shown is default. Suggested: *
					'show_import_export' => true,
					// Shows the Import/Export panel when not used as a field.

					// CAREFUL -> These options are for advanced use only
					'transient_time' => 60 * MINUTE_IN_SECONDS,
					'output' => true,
					// Global shut-off for dynamic CSS output by the framework. Will also disable google fonts output
					'output_tag' => true,
					// Allows dynamic CSS to be generated for customizer and google fonts, but stops the dynamic CSS from going to the head
					// 'footer_credit' => '', // Disable the footer credit of Redux. Please leave if you can help it.

					// FUTURE -> Not in use yet, but reserved or partially implemented. Use at your own risk.
					'database' => '',
					// possible: options, theme_mods, theme_mods_expanded, transient. Not fully functional, warning!
					'system_info' => false,
					// REMOVE

					// HINTS
					'hints' => array (
							'icon' => 'icon-question-sign',
							'icon_position' => 'right',
							'icon_color' => 'lightgray',
							'icon_size' => 'normal',
							'tip_style' => array (
									'color' => 'light',
									'shadow' => true,
									'rounded' => false,
									'style' => ''
							),
							'tip_position' => array (
									'my' => 'top left',
									'at' => 'bottom right'
							),
							'tip_effect' => array (
									'show' => array (
											'effect' => 'slide',
											'duration' => '500',
											'event' => 'mouseover'
									),
									'hide' => array (
											'effect' => 'slide',
											'duration' => '500',
											'event' => 'click mouseleave'
									)
							)
					)
			);

			// ADMIN BAR LINKS -> Setup custom links in the admin bar menu as external items.
			$this->args ['admin_bar_links'] [] = array (
					'id' => 'redux-docs',
					'href' => 'http://docs.reduxframework.com/',
					'title' => __ ( 'Documentation', 'redux-framework-demo' )
			);

			$this->args ['admin_bar_links'] [] = array (
					// 'id' => 'redux-support',
					'href' => 'https://github.com/ReduxFramework/redux-framework/issues',
					'title' => __ ( 'Support', 'redux-framework-demo' )
			);

			$this->args ['admin_bar_links'] [] = array (
					'id' => 'redux-extensions',
					'href' => 'reduxframework.com/extensions',
					'title' => __ ( 'Extensions', 'redux-framework-demo' )
			);

			// SOCIAL ICONS -> Setup custom links in the footer for quick links in your panel footer icons.
			$this->args ['share_icons'] [] = array (
					'url' => 'https://github.com/ReduxFramework/ReduxFramework',
					'title' => 'Visit us on GitHub',
					'icon' => 'el-icon-github'
			);
			// 'img' => '', // You can use icon OR img. IMG needs to be a full URL.

			$this->args ['share_icons'] [] = array (
					'url' => 'https://www.facebook.com/pages/Redux-Framework/243141545850368',
					'title' => 'Like us on Facebook',
					'icon' => 'el-icon-facebook'
			);
			$this->args ['share_icons'] [] = array (
					'url' => 'http://twitter.com/reduxframework',
					'title' => 'Follow us on Twitter',
					'icon' => 'el-icon-twitter'
			);
			$this->args ['share_icons'] [] = array (
					'url' => 'http://www.linkedin.com/company/redux-framework',
					'title' => 'Find us on LinkedIn',
					'icon' => 'el-icon-linkedin'
			);

			// Panel Intro text -> before the form
			if (! isset ( $this->args ['global_variable'] ) || $this->args ['global_variable'] !== false) {
				if (! empty ( $this->args ['global_variable'] )) {
					$v = $this->args ['global_variable'];
				} else {
					$v = str_replace ( '-', '_', $this->args ['opt_name'] );
				}
				$this->args ['intro_text'] = sprintf ( __ ( '<p>Did you know that Redux sets a global variable for you? To access any of your saved options from within your code you can use your global variable: <strong>$%1$s</strong></p>', 'redux-framework-demo' ), $v );
			} else {
				$this->args ['intro_text'] = __ ( '<p>This text is displayed above the options panel. It isn\'t required, but more info is always better! The intro_text field accepts all HTML.</p>', 'redux-framework-demo' );
			}

			// Add content after the form.
			$this->args ['footer_text'] = __ ( '<p>This text is displayed below the options panel. It isn\'t required, but more info is always better! The footer_text field accepts all HTML.</p>', 'redux-framework-demo' );
		}
		public function validate_callback_function($field, $value, $existing_value) {
			$error = true;
			$value = 'just testing';

			/*
			 * do your validation
			 *
			 * if(something) {
			 * $value = $value;
			 * } elseif(something else) {
			 * $error = true;
			 * $value = $existing_value;
			 *
			 * }
			 */

			$return ['value'] = $value;
			$field ['msg'] = 'your custom error message';
			if ($error == true) {
				$return ['error'] = $field;
			}

			return $return;
		}
		public function class_field_callback($field, $value) {
			print_r ( $field );
			echo '<br/>CLASS CALLBACK';
			print_r ( $value );
		}
	}

	global $reduxConfig;
	$reduxConfig = new Redux_Framework_sample_config ();
} else {
	echo "The class named Redux_Framework_sample_config has already been called. <strong>Developers, you need to prefix this class with your company name or you'll run into problems!</strong>";
}

/**
 * Custom function for the callback referenced above
 */
if (! function_exists ( 'redux_my_custom_field' )) :
	function redux_my_custom_field($field, $value) {
		print_r ( $field );
		echo '<br/>';
		print_r ( $value );
	}






    endif;

/**
 * Custom function for the callback validation referenced above
 */
if (! function_exists ( 'redux_validate_callback_function' )) :
	function redux_validate_callback_function($field, $value, $existing_value) {
		$error = true;
		$value = 'just testing';

		/*
		 * do your validation
		 *
		 * if(something) {
		 * $value = $value;
		 * } elseif(something else) {
		 * $error = true;
		 * $value = $existing_value;
		 *
		 * }
		 */

		$return ['value'] = $value;
		$field ['msg'] = 'your custom error message';
		if ($error == true) {
			$return ['error'] = $field;
		}

		return $return;
	}





    endif;